﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Linq;
using QuanLyDaiLy.Model;
using System.Data.OleDb;

namespace QuanLyDaiLy.Context
{
    public class CDaiLyContext:DataContext, IContext<CDaiLy>
    {
        #region Variable
        Table<CDaiLy> table;
        #endregion 

        #region Constructor
        public CDaiLyContext(OleDbConnection connection)
            : base(connection)
        {
            table = GetTable<CDaiLy>();
        }
        #endregion

        #region Public Method
        /// <summary>
        /// Thêm vào một đại lý vào bảng DaiLy
        /// </summary>
        /// <param name="obj">Đối tượng CDaiLy</param>
        public void Them(CDaiLy obj)
        {
            table.InsertOnSubmit(obj);
            this.SubmitChanges();
        }

        /// <summary>
        /// Cập nhật lại thông tin của đại lý
        /// </summary>
        /// <param name="obj">Đối tượng đã được cập nhật</param>
        public void CapNhat(CDaiLy obj)
        {
            var daily = LayThongTin(obj.MaDaiLy);

            daily.MaLoaiDaiLy = obj.MaLoaiDaiLy;
            daily.MaQuan = obj.MaQuan;
            daily.NgayTiepNhan = obj.NgayTiepNhan;
            daily.TenDaiLy = obj.TenDaiLy;
            daily.TienNo = obj.TienNo;
            daily.Email = obj.Email;
            daily.DiaChi = obj.DiaChi;

            this.SubmitChanges();
        }

        /// <summary>
        /// Xóa một đại lý thuộc bảng CDaiLy
        /// </summary>
        /// <param name="maso">Mã số của Đại Lý cần xóa</param>
        public void Xoa(ulong maso)
        {
            var daily = LayThongTin(maso);

            table.DeleteOnSubmit(daily);
            this.SubmitChanges();
        }

        /// <summary>
        /// Lấy thông tin của Đại Lý dựa vào MaDaiLy
        /// </summary>
        /// <param name="maso">MaDaiLy cần lấy thông tin</param>
        /// <returns>Trả về đối tượng CDAiLy</returns>
        public CDaiLy LayThongTin(ulong maso)
        {
            var query = from e in table where e.MaDaiLy == maso select e;

            return query.First();
        }

        /// <summary>
        /// Lấy Danh sách tất cả đại lý
        /// </summary>
        /// <returns>List CDaiLy</returns>
        public List<CDaiLy> LayDanhSachTatCa()
        {
            var query = from e in table select e;

            return query.ToList();
        }
        #endregion
    }
}
